|                   |                                                                   |                                             |                          | MSF                                                         | P430 Addres                           | sing M                   | odes                                                                                                  |                                                  |                                       |                                              |                             |                                         |                          | М        | SP430 E                     | mulated                                        | d Ins                                                   | truction     | ns                       |                                                  |                                                       |              |                    |  |
|-------------------|-------------------------------------------------------------------|---------------------------------------------|--------------------------|-------------------------------------------------------------|---------------------------------------|--------------------------|-------------------------------------------------------------------------------------------------------|--------------------------------------------------|---------------------------------------|----------------------------------------------|-----------------------------|-----------------------------------------|--------------------------|----------|-----------------------------|------------------------------------------------|---------------------------------------------------------|--------------|--------------------------|--------------------------------------------------|-------------------------------------------------------|--------------|--------------------|--|
| Ad<br>0           |                                                                   | Register n ≠ 3                              | Syntax<br>Rn             | Dogiet                                                      | tor direct. The o                     | norand is                | Description the contents of Rn. A <sub>d</sub> =0                                                     |                                                  | Mnem                                  |                                              |                             |                                         | eration                  |          |                             | Emula                                          |                                                         |              |                          | Descri                                           | otion                                                 |              |                    |  |
| 1                 | 01 ds                                                             | n ≠ 0, 2, 3                                 | x(Rn)                    | Indexe                                                      | ed. The operanc                       | is in me                 | mory at address Rn+x. is in memory at the address held in                                             |                                                  | Arithn<br>ADC(.B                      |                                              | istructio<br>dst            | ns<br>dst+C→                            | lst                      |          | ΑĽ                          | DC(.B or .'                                    | W) #0                                                   | ),dst        | Ac                       | dd carry t                                       | o destinat                                            | ion          |                    |  |
| -                 |                                                                   | n ≠ 0, 2, 3<br>n ≠ 0, 2, 3                  |                          | ter indirect. The<br>ct auto-increment<br>essing modes      |                                       |                          | DADC(.B or .W) dst<br>DEC(.B or .W) dst                                                               |                                                  | dst+C→dst (decimally)<br>dst-1→dst    |                                              |                             |                                         | DD(.B or .<br>B(.B or .W |          |                             |                                                | Decimal add carry to destination  Decrement destination |              |                          |                                                  |                                                       |              |                    |  |
| 1                 |                                                                   | 0 (PC)                                      |                          | DECD(.B or .W) dst dst-2→dst<br>INC(.B or .W) dst dst+1→dst |                                       |                          |                                                                                                       |                                                  |                                       | SUB(.B or .W) #2,dst<br>ADD(.B or .W) #1,dst |                             |                                         |                          |          |                             | destinatio                                     |                                                         |              |                          |                                                  |                                                       |              |                    |  |
| -                 | Addressing modes using R2 (SR) and R3 (CG), special-case decoding |                                             |                          |                                                             |                                       |                          |                                                                                                       |                                                  |                                       | 3 or .W)<br>or .W) (                         | dst                         | dst+2→                                  | ,                        |          |                             |                                                |                                                         | dst          | In                       | crement                                          | destinatio                                            | n twice      | .NOT. carry        |  |
| 1                 | 01 ds<br>10 s                                                     | 2 (SR)<br>2 (SR)                            |                          |                                                             | ute. The operan<br>ant. The operan    |                          | emory at address x.                                                                                   |                                                  | эвс(.в                                | or.w)                                        | ist                         | dst+0FF                                 |                          |          | 30                          | BC(.B 0F.\                                     | wj#0,                                                   | ,ust         |                          | om dest.                                         | urce and t                                            | orrow /      | .NOT. carry        |  |
| -                 | 11 s<br>00 s                                                      | 2 (SR)<br>3 (CG)                            | #8                       | Const                                                       | ant. The operar<br>ant. The operar    | ıd is the c              | onstant 8.                                                                                            |                                                  | Mnemo                                 |                                              |                             |                                         | ration                   |          |                             | Emulatio                                       | on                                                      |              |                          | Descrip                                          | tion                                                  |              |                    |  |
| -                 | 01 s<br>10 s                                                      | 3 (CG)<br>3 (CG)                            | #1                       | Const                                                       |                                       | d is the c               | onstant 1. There is no index word.                                                                    |                                                  | Logical<br>INV(.B o                   |                                              |                             | ontrol In<br>NOT.dst-                   | structions<br>dst        |          | XOR                         | (.B or .W)                                     | #0(FF                                                   | F)FFh,dst    | Inv                      | ert bits ir                                      | destinatio                                            | on           |                    |  |
| -                 | 10 S                                                              | 3 (CG)                                      |                          | Const                                                       | ant. The operar<br>SP430 Instru       | d is the c               | onstant -1.                                                                                           |                                                  | RLA(.B o                              | r .W) d                                      |                             | $LSB+1 \leftarrow LSB \leftarrow 0$     |                          |          |                             | ADD(.B or .W) dst,dst                          |                                                         |              |                          | Rotate left arithmetically                       |                                                       |              |                    |  |
|                   |                                                                   | 10 9 8                                      |                          | 5 4                                                         | 3 2 1 0                               |                          | Instruction                                                                                           |                                                  |                                       |                                              |                             | C←MSB←MSB-1 ADDC(.B or .<br>LSB+1←LSB←C |                          |          |                             |                                                |                                                         | dst          | Rot                      | ate left th                                      | rough car                                             | ry           |                    |  |
| <b>0 0</b>        |                                                                   | 0 opc                                       |                          |                                                             | register<br>register                  | RRC F                    | Single-operand arithmetic<br>Rotate right through carry                                               | Program                                          | Flow C                                |                                              |                             |                                         |                          |          |                             |                                                |                                                         |              |                          |                                                  |                                                       |              |                    |  |
| 0 0               | 0 1 0                                                             | 0 0 0                                       | 1 0                      | As                                                          | register                              | SWPB                     | Swap bytes                                                                                            |                                                  | BR dst<br>DINT                        |                                              |                             | 0→GIE                                   |                          |          |                             |                                                | MOV dst,PC<br>BIC #8,SR                                 |              |                          |                                                  | Branch to destination<br>Disable (general) interrupts |              |                    |  |
| 0 0               |                                                                   | 0 0 1                                       | 0 B/W<br>1 0             | As                                                          | register<br>register                  |                          | Rotate right arithmetic<br>lign extend byte to word                                                   |                                                  | EINT<br>NOP<br>RET                    |                                              |                             | 1→GIE<br>None<br>@SP→PC SP+2→SP         |                          |          |                             | BIS #8,SR<br>MOV #0,R3<br>MOV @SP+,PC          |                                                         |              |                          | operation                                        | eral) interi<br>1<br>subroutin                        | -            |                    |  |
| 0 0               |                                                                   | 0 1 0                                       | 0 B/W<br>1 0             | As<br>As                                                    | register<br>register                  |                          | Push value onto stack Subroutine call; push PC and move                                               | source to PC                                     | Mnemo                                 | mio.                                         | •                           |                                         | ration                   | _        |                             | Emulatio                                       |                                                         |              |                          | Descrip                                          |                                                       |              |                    |  |
| 0 0               |                                                                   | 0 1 1                                       | 0 0                      | 0 0                                                         |                                       |                          | Return from interrupt; pop SR then p                                                                  |                                                  | Data In:                              | structi                                      |                             | •                                       | ation                    |          |                             |                                                |                                                         |              |                          |                                                  |                                                       |              |                    |  |
| 0 0               | T 1 1                                                             |                                             | 10-bit s                 |                                                             |                                       | ļ                        | Conditional jump; PC = PC + 2×                                                                        | offset                                           | CLR(.B o                              | r.W) d                                       |                             | 0→dst<br>0→C                            |                          |          | BIC                         | /(.B or .W)<br>#1,SR                           | ) #0,ds                                                 | st           | Cle                      | ar destina<br>ar carry f                         | lag                                                   |              |                    |  |
| 0 0               | 1 0 0                                                             | 1                                           | 10-bit :                 |                                                             |                                       |                          | NZ Jump if not equal/zero Z Jump if equal/zero                                                        |                                                  | CLRN<br>CLRZ<br>POP(.B o              |                                              |                             | 0→N<br>0→Z                              |                          |          | BIC                         | BIC #4,SR<br>BIC #2,SR                         |                                                         |              |                          | ar negativ<br>ar zero fla                        | ag                                                    |              |                    |  |
| 0 0               |                                                                   | 0                                           | 10-bit :                 | signed                                                      | offset                                | JNC/J                    | JNC/JLO Jump if no carry/lower JC/JHS Jump if carry/higher or same                                    |                                                  |                                       |                                              | :                           | @SP→temp<br>SP+2→SP                     |                          |          |                             | (.B or .W)                                     | j @SP∙                                                  | +,ast        | Pop                      | byte/wo                                          | ord from st                                           | ack to d     | estination         |  |
| 0 0               | 1 1 0                                                             | 0                                           | 10-bit :                 | signed                                                      | offset                                | <b>JN</b> Jur            | mp if negative                                                                                        |                                                  | SETC<br>SETN                          |                                              |                             |                                         | temp→dst<br>1→C<br>1→N   |          |                             |                                                | BIS #1,SR<br>BIS #4,SR                                  |              |                          |                                                  | flag                                                  |              |                    |  |
| 0 0               |                                                                   | 0                                           | 10-bit :                 |                                                             |                                       |                          | ump if greater or equal np if less                                                                    |                                                  | SETN<br>SETZ<br>TST(.B or .W) dst     |                                              |                             | 1→N<br>1→Z<br>dst+0FFFFh+1              |                          |          |                             | BIS #4,SR<br>BIS #2,SR<br>CMP(.B or .W) #0,dst |                                                         |              |                          | Set negative flag Set zero flag Test destination |                                                       |              |                    |  |
| 0 0               |                                                                   | 1                                           | 10-bit                   |                                                             |                                       |                          | ump (unconditionally)                                                                                 |                                                  |                                       | 000                                          |                             | dst + 0FFl                              |                          | 0        |                             | 1C0                                            |                                                         |              |                          | 2C0                                              |                                                       | 340          | 380 3C0            |  |
| <b>op</b>         |                                                                   | source                                      | Ad B/W                   | _                                                           | destination<br>destination            | MOV                      | Two-operand arithmetic  Move source to destination                                                    |                                                  | 0xxx<br>4xxx                          |                                              |                             |                                         |                          | 4        |                             |                                                | F                                                       |              |                          |                                                  |                                                       |              |                    |  |
| 0 1               | 0 1                                                               | source                                      | Ad B/W                   | As                                                          | destination                           | ADD A                    | Add source to destination                                                                             |                                                  | 8xxx                                  |                                              |                             |                                         |                          | #        |                             |                                                |                                                         |              |                          |                                                  |                                                       |              |                    |  |
| 0 1               | 1 0                                                               | source                                      | Ad B/W                   |                                                             | destination<br>destination            | _                        | Add source and carry to destination<br>Subtract source from destination (w                            |                                                  | Cxxx<br>1xxx                          | RRC                                          | RRC.B                       | SWPB                                    | RF                       | RA.      | RRA.B SX                    | т                                              | PUS                                                     | SH PUSH.     | B CALL                   |                                                  | RETI                                                  |              |                    |  |
| 1 0               |                                                                   | source                                      | Ad B/W                   |                                                             | destination                           | SUB 9                    | Subtract source from destination                                                                      |                                                  | 14xx<br>18xx                          |                                              | -                           |                                         |                          | 7        |                             |                                                | $\vdash$                                                |              | -                        |                                                  |                                                       | _            |                    |  |
| 1 0               |                                                                   | source                                      | Ad B/W                   |                                                             | destination<br>destination            |                          | Compare (pretend to subtract) source from Decimal add source to destination                           |                                                  | 1Cxx                                  |                                              |                             |                                         |                          | 1        |                             |                                                |                                                         |              |                          |                                                  |                                                       |              |                    |  |
| 1 0               | 1 1 0 0                                                           | source                                      | Ad B/W                   |                                                             | destination<br>destination            |                          | est bits of source AND destination<br>it clear (dest &= ~src)                                         |                                                  | 20xx<br>24xx                          |                                              |                             |                                         |                          |          |                             | JNE/JN<br>JEQ/JZ                               |                                                         |              |                          |                                                  |                                                       |              |                    |  |
| 1 1               | 0 1                                                               | source                                      | Ad B/W                   | As                                                          | destination                           | BIS Bi                   | t set (logical OR)                                                                                    |                                                  | 28xx<br>2Cxx                          |                                              |                             |                                         |                          |          |                             | JNC<br>JC                                      |                                                         |              |                          |                                                  |                                                       |              |                    |  |
| 1 1               | 1 0                                                               | source<br>source                            | Ad B/W                   |                                                             | destination destination               |                          | Exclusive or source with destination<br>ogical AND source with destination                            |                                                  | 30xx                                  |                                              |                             |                                         |                          |          |                             | JN                                             |                                                         |              |                          |                                                  |                                                       |              |                    |  |
| Special Re        | gisters: PC<br>SR                                                 | C (Program C<br>C (Status Regi<br>Operand(s | ounter)=R0;<br>ster)=R2; |                                                             | SP (Stack<br>CG (Cor                  | Pointer)=:<br>stants Ger | R1;<br>merator)=R3;                                                                                   | * changes based on c<br>- not affecte<br>V N Z C | 3000                                  |                                              |                             |                                         |                          |          |                             | JGE<br>JL                                      |                                                         |              |                          |                                                  |                                                       |              |                    |  |
| 1 @               | ADC(.B)                                                           | dst                                         | Add C to                 |                                                             | nation                                | Description              | V N Z C                                                                                               | 3Cxx JMP<br>4xxx MOV, MOV,B                      |                                       |                                              |                             |                                         |                          |          |                             |                                                |                                                         |              |                          |                                                  |                                                       |              |                    |  |
| 2 3               | ADD(.B)<br>ADDC(.B)                                               | src,dst<br>src,dst                          |                          |                                                             | destination<br>d C to destinati       | on                       | src+dst→dst<br>src+dst+C→dst                                                                          | * * * *                                          | 5xxx                                  |                                              | ADD, ADD.B<br>ADDC, ADDC.B  |                                         |                          |          |                             |                                                |                                                         |              |                          |                                                  |                                                       |              |                    |  |
| 4                 | AND(.B)<br>BIC(.B)                                                | src,dst<br>src,dst                          |                          |                                                             | nd destination<br>estination          |                          | src .and. $dst \rightarrow dst$<br>not.src .and. $dst \rightarrow dst$                                | 0 * * *                                          | 6xxx<br>7xxx                          |                                              |                             |                                         |                          |          |                             | SUBC,                                          | SUB                                                     | C.B          |                          |                                                  |                                                       |              |                    |  |
| 6                 | BIS(.B)                                                           | src,dst                                     | Set bits i               | n desti                                                     | ination                               |                          | $src.or.dst \to dst$                                                                                  | 0 * * *                                          | 8xxx<br>9xxx                          |                                              |                             |                                         |                          |          |                             | SUB, S                                         |                                                         |              |                          |                                                  |                                                       |              |                    |  |
| 7<br>8 <b>©</b>   | BIT(.B)<br>BR                                                     | src,dst<br>dst                              | Test bits<br>Branch t    |                                                             |                                       |                          | src .and. dst<br>dst → PC                                                                             | 0 * * * *                                        | Axxx<br>Bxxx                          | DADD, DADD.B<br>BIT, BIT.B                   |                             |                                         |                          |          |                             |                                                |                                                         |              |                          |                                                  |                                                       |              |                    |  |
| 9<br>10 ©         | CALL<br>CLR(.B)                                                   | dst<br>dst                                  | Call dest<br>Clear des   |                                                             |                                       |                          | $PC+2 \rightarrow stack, dst \rightarrow PC$<br>$0 \rightarrow dst$                                   |                                                  | Cxxx                                  |                                              | BIC, BIC.B                  |                                         |                          |          |                             |                                                |                                                         |              |                          |                                                  |                                                       |              |                    |  |
| 11 ©              | CLRC                                                              |                                             | Clear C                  |                                                             |                                       |                          | 0→C<br>0→N                                                                                            |                                                  | Dxxx<br>Exxx                          |                                              | BIS, BIS.B<br>XOR, XOR.B    |                                         |                          |          |                             |                                                |                                                         |              |                          |                                                  |                                                       |              |                    |  |
| 12 ©<br>13 ©      | CLRZ                                                              |                                             | Clear N<br>Clear Z       |                                                             |                                       |                          | 0→Z                                                                                                   | 0 -                                              | Fxxx                                  |                                              |                             |                                         |                          |          |                             | AND, A                                         | -                                                       |              |                          |                                                  | * IF NEEDED                                           |              | * IF NEEDED        |  |
| 14<br>15 ©        | CMP(.B)<br>DADC(.B)                                               | src,dst<br>dst                              |                          |                                                             | ce and destinati<br>lly to destinatio |                          | $dst \cdot src$<br>$dst + C \rightarrow dst$ (decimally)                                              | * * * *                                          | 0(Rn) = @Rn w<br>mov.w R              | nen source                                   |                             | ne code<br>606                          | opcode<br>0 1 0          | 0        | source Reg                  | (3031)                                         | ∽w As<br>0 0                                            |              | estination<br>6          | Ad                                               | ditional Data 1                                       |              | Additional Data 2  |  |
| 16<br>17 ©        | DADD(.B)<br>DEC(.B)                                               | src,dst<br>dst                              | Add sour                 |                                                             | d C decimally to                      | o dst                    | $src + dst + C \rightarrow dst$ (decimally)<br>$dst \cdot 1 \rightarrow dst$                          | * * * * *                                        | add.b R4<br>bit.w @R7                 | , R12                                        | B7                          | 148<br>72C                              | 0 1 0                    | 1        | 7                           | 0 0                                            | 1 0<br>0 1                                              | 0            | 8<br>C                   |                                                  | •                                                     |              | -                  |  |
| 18 ©              | DECD(.B)                                                          |                                             | Double-c                 | lecrem                                                      | nent destination                      | 1                        | $dst \cdot 2 \rightarrow dst$                                                                         | * * * *                                          | bit.b 0(R7)<br>bic.b 2(R8),           | 0(R8)                                        | CSDS O                      | 76F<br>002 0000                         | 1 0 1                    | 0        | 7                           | 1 1                                            | 1 1                                                     | 1            | F<br>8                   | $\pm \overline{}$                                | 0002                                                  | Ŧ            | 0000               |  |
| 19 ©              | EINT                                                              |                                             | Disable i<br>Enable ii   | nterru                                                      | pts                                   |                          | $0 \to \text{GIE}$ $1 \to \text{GIE}$                                                                 |                                                  | bic.w 2(R8)<br>bis.w #0xAA<br>rra.b R | AA, R11                                      | D03B                        | AAAA<br>4A                              | 1 1 0                    | 1        | 8<br>0<br>0001              | 0 0                                            | 0 0                                                     | 1            | 7<br>B                   | +                                                | AAAA                                                  | $\pm$        |                    |  |
| 21 ©<br>22 ©      |                                                                   | dst<br>dst                                  | Increme<br>Double-i      |                                                             | tination<br>ent destination           |                          | $dst +1 \rightarrow dst$<br>$dst+2 \rightarrow dst$                                                   | * * * *                                          | rra.b R:<br>rrc.w R<br>jmp LAE        | 11                                           | 10                          | IOB<br>XXX XXXX]                        | 0 0 0 0 0 0 0 0 1        | 1        | 0001<br>0000<br>11xx        | 0 0                                            | 1 0<br>0 0<br>x x                                       |              | В                        | s)                                               |                                                       | #            |                    |  |
| 23 ©<br>24        |                                                                   | dst<br>label                                | Invert de                |                                                             | ion<br>Jump if higher o               | or same                  | $.not.dst \rightarrow dst$                                                                            | * * * *                                          | cmp R13,                              | 2(R8)                                        | 9D88                        | 0002<br>(XXX XXXX)                      | 1 0 0                    | 1        | D<br>00xx                   | 1 (                                            | 0 0                                                     |              | 8                        |                                                  | 0002                                                  | +            |                    |  |
| 25                | JEQ/JZ                                                            | label                                       | Jump if e                | qual/                                                       | Jump if Z set                         | . vanie                  |                                                                                                       |                                                  | rla.b R:                              | .0                                           | 5.4                         | code) 🏤                                 | 0 1 0                    |          | A                           |                                                | 1 0                                                     |              | A                        |                                                  |                                                       |              |                    |  |
| 26<br>27          | JGE<br>JL                                                         | label<br>label                              | Jump if g<br>Jump if l   |                                                             | or equal                              |                          |                                                                                                       |                                                  | rlc.w R:<br>addc.w R1:                | , R11                                        | <b>◆</b> (emulated          |                                         | 0 1 1                    | 0        | В                           | 0 0                                            | 0 0                                                     | 0            | В                        |                                                  |                                                       |              |                    |  |
| 28<br>29          | JMP<br>JN                                                         | label<br>label                              | Jump<br>Jump if 1        | N set                                                       |                                       |                          | $PC + 2 \times offset \rightarrow PC$                                                                 |                                                  | inv.w R                               | FF, R10                                      | <b>€</b> (emulated          |                                         | 1 1 1                    | 0        | 3                           | 0 0                                            | 0 1                                                     | 1            | A                        |                                                  |                                                       |              |                    |  |
| 30<br>31          | JNC/JLO<br>JNE/JNZ                                                | label<br>label                              | Jump if (                | C not s                                                     | set/Jump if low<br>ual/Jump if Z n    |                          |                                                                                                       |                                                  | add.w #0x00                           |                                              | € (emulated                 | code) 🏚                                 | 0 1 0                    |          | 3<br>tion is comp           |                                                | 0 0                                                     |              | B<br>d on thes           | e condis.                                        | ne                                                    |              |                    |  |
| 32                | MOV(.B)                                                           | src,dst                                     | Move sor                 | urce to                                                     | destination                           | or our                   | $src \rightarrow dst$                                                                                 |                                                  |                                       | erflow: "                                    | signed" o                   | verflow - le                            |                          |          | switched fro                |                                                | or from                                                 | m (-) to (+) |                          | _ conunct                                        |                                                       |              |                    |  |
| 33 ©<br>34 ©      | POP(.B)                                                           | dst                                         |                          | from                                                        | stack to destina                      | ition                    | @SP $\rightarrow$ dst, SP+2 $\rightarrow$ SP                                                          |                                                  |                                       |                                              | add.w                       |                                         | 0111                     | 111      | inc.w<br>1 1111 11          | · .                                            |                                                         | inc          | d.b<br>111 11            | 10                                               |                                                       |              | 11 0000            |  |
| 35<br>36 <b>ⓒ</b> | PUSH(.B)<br>RET                                                   | src                                         | Push sou<br>Return fi    |                                                             | nto stack<br>ubroutine                |                          | $SP \cdot 2 \rightarrow SP$ , $src \rightarrow @SP$<br>$@SP \rightarrow PC$ , $SP + 2 \rightarrow SP$ |                                                  | +0                                    | 111 01<br>011 01                             | 00 001<br>00 001            | 0 1011<br>0 1011                        | 1000                     | 000      | 0 0000 00                   | 00                                             |                                                         | 0 0000 1     | .000 00                  |                                                  | +<br>0000 0                                           | 10           | 00 1000<br>11 1000 |  |
| 37                | RETI                                                              | de*                                         | Return f                 | rom in                                                      | nterrupt                              |                          | -, 01                                                                                                 | * * * *                                          | Neg                                   | gative: T                                    |                             | digit (MS                               | 3) is 1 - the n          | umb      | er "negative"               | if you are u                                   |                                                         | ary          |                          |                                                  |                                                       |              |                    |  |
| 39 €              | RLC(.B)                                                           | dst<br>dst                                  | Rotate le                | ft thro                                                     |                                       |                          |                                                                                                       | * * * *                                          |                                       |                                              | cmp.w<br>010 010            |                                         | 0101                     | 000      | inv.w<br>0 1111 10          | 10                                             | 000                                                     | 0 0000 de    | c.b<br>1000 00           | 00                                               |                                                       |              | 00 0101            |  |
| 40<br>41          | RRA(.B)<br>RRC(.B)                                                | dst<br>dst                                  | Rotate ri<br>Rotate ri   |                                                             | ithmetically<br>rough C               |                          |                                                                                                       | 0 * * *                                          | 1                                     | 111 11                                       | 100 111<br>11 001           | 1 0101                                  | 1010                     | 111      | 1 0000 01                   | 01                                             | 000                                                     | 0 0000 1     | 111 11                   | 11                                               | 0000 0                                                | 00<br>000 11 | 00 0111<br>11 1110 |  |
| 42 ©<br>43 ©      | SBC(.B)                                                           | dst                                         |                          |                                                             | ) from destinat                       | ion                      | $dst + 0FFFFh + C \rightarrow dst$<br>$1\rightarrow C$                                                | * * * *                                          | Zer                                   | o: All th                                    | e bits are                  | υ                                       |                          |          | rra.w                       | examples                                       | in bind                                                 |              | d.b                      |                                                  |                                                       | xor          | h                  |  |
| 44 ©              | SETN                                                              |                                             | Set N                    |                                                             |                                       |                          | 1→N                                                                                                   | - 1                                              |                                       |                                              | 300.W<br>010 010<br>010 010 |                                         | 0000                     | 000      | 0 0000 00                   | 01                                             |                                                         | 1            | a.b<br>1010 10<br>101 01 |                                                  |                                                       | 00           | 10 1101<br>10 1101 |  |
| 45 <b>©</b> 46    | SUB(.B)                                                           | src,dst                                     |                          |                                                             | e from destinati                      |                          | $1 \rightarrow Z$<br>dst + .not.src + 1 $\rightarrow$ dst                                             | * * * *                                          | 0                                     | 000 O                                        | 000 000                     | 0000                                    |                          |          | 0 0000 00<br>th space - a d |                                                |                                                         | 0 0000 0     | 000 00                   |                                                  | 0000 0                                                |              | 00 0000            |  |
| 47<br>48          | SUBC(.B)<br>SWPB                                                  | src,dst<br>dst                              | Subtract<br>Swap byt     |                                                             | e and not(C) fro                      | om dst                   | $dst + .not.src + C \rightarrow dst$                                                                  | * * * *                                          |                                       |                                              | add.w                       |                                         |                          |          | rra.w                       | examples                                       | in bind                                                 | ary<br>rli   | c. <i>b</i>              |                                                  |                                                       | rrc          |                    |  |
| 49                | SXT                                                               | dst                                         | Extend s                 | ign                                                         | n                                     |                          | dst+0FFFFh+1                                                                                          | 0 * * * *                                        |                                       | 1000                                         | 0000                        | 0000 00<br>0000 00                      | 01                       |          | 0 0000 00                   |                                                |                                                         | 0000 000     | 00 1000                  |                                                  |                                                       | 000 11       | 01 1011            |  |
| 50 <b>©</b>       | TST(.B)<br>XOR(.B)                                                | dst<br>src,dst                              | Test dest<br>Exclusive   |                                                             | n<br>source and desti                 | nation                   | dst+0FFFFh+1<br>$src.xor. dst \rightarrow dst$                                                        | * * * *                                          | 15                                    | 14                                           | 13                          | 12                                      |                          | 001<br>o | 9 0000 0                    | 8                                              | 7                                                       | 6            | 5                        | 4                                                | 3                                                     | 2            | 10 1101 (1)        |  |
|                   |                                                                   |                                             |                          |                                                             |                                       |                          |                                                                                                       |                                                  |                                       |                                              | F                           | Reserved                                |                          |          |                             | v sc                                           | G1                                                      | SCG0         | OFF                      | CPU<br>OFF                                       | GIE                                                   | 7            | z c                |  |
|                   |                                                                   |                                             |                          |                                                             |                                       |                          |                                                                                                       |                                                  |                                       |                                              |                             |                                         |                          |          |                             |                                                |                                                         |              |                          |                                                  |                                                       |              |                    |  |

| Low Power Mo                                                       | [adae                                                                              |                                 |                     |                               |                                   |                                        |              | Serial_MSP.c                                                                                                                                                           |                                |                                              |                                                      |                                                                      | 22.3.1 AD                                     | C10CTL0,             | ADC10 Cont                                             | trol Register 0                                                                                                  |                                             |                                                                                  |                       |                    |
|--------------------------------------------------------------------|------------------------------------------------------------------------------------|---------------------------------|---------------------|-------------------------------|-----------------------------------|----------------------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|----------------------------------------------|------------------------------------------------------|----------------------------------------------------------------------|-----------------------------------------------|----------------------|--------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|---------------------------------------------|----------------------------------------------------------------------------------|-----------------------|--------------------|
| SCG1 SCG0                                                          | G0 OSCOFF                                                                          | CPUOFF                          | Mode                |                               |                                   | locks Status                           |              | void serial_init(void) {<br>P1SEL = 0x04:                                                                                                                              | // Select UA                   | ART as the pin funct                         | tion                                                 |                                                                      | 15                                            | 14                   | 13                                                     | 12                                                                                                               | 11                                          | 10                                                                               | 9                     | 8                  |
| 0 0                                                                | _                                                                                  | 0                               | Active<br>LPM0      | CPU, MCLK a                   | are disabled, SI                  | abled clocks are ac<br>SMCLK, ACLK are | active       | P1SEL2 = 0x04;<br>UCA0CTL1  = UCSWRST;                                                                                                                                 | // Disable U.                  | ART module for co                            | onfiguration                                         |                                                                      | rw-(0)                                        | SREFx<br>rw-(0)      | rw-(0)                                                 | rw-(0)                                                                                                           | rw-(0)                                      | ADC10SR<br>rw-(0)                                                                | rw-(0)                | REFBURST<br>rw-(0) |
| 0 1                                                                | 0                                                                                  | 1                               | LPM1                |                               |                                   | OCO and DC gener<br>sed for SMCLK. At  |              | UCA0CTL0 = 0x00;<br>UCA0CTL1 = 0xC0;                                                                                                                                   | // SMCLK s                     | LSB first, 8-bit dat<br>source, keep in rese | t state                                              |                                                                      | 7<br>MSC                                      | 6<br>REF2_5          | 5<br>V REFON                                           | 4<br>ADC100N                                                                                                     | 3<br>ADC10IE                                | 2<br>ADC10IFG                                                                    | 1<br>ENC              | 0<br>ADC10SC       |
| 1 0                                                                | 0                                                                                  | 1                               | LPM2                | CPU, MCLK,                    | , SMCLK, DCO :<br>bled, ACLK is a | are disabled. DC g                     | generator    | UCA0BR0 = 104;<br>UCA0MCTL = 0x02;                                                                                                                                     | // 9600 Bauc<br>// 2nd Stage   | d rate - Assumes 1 :<br>modulation = 1, O    | versampling off                                      | 000 / 9600 = 104)                                                    | rw-(0)                                        | rw-(0)<br>Can be mod | rw-(0)<br>tified only when EN                          | rw-(0)<br>4C = 0                                                                                                 | rw-(0)                                      | rw-(0)                                                                           | rw-(0)                | rw-(0)             |
| 1 1                                                                | 0                                                                                  | 1                               | LPM3                |                               | SMCLK, DCO                        | are disabled. DC g                     | generator    | IE2 = 0x00;<br>UCA0CTL1 &= ~UCSWRST;                                                                                                                                   | // Enable UA                   | // Interrupts<br>ART module                  | disabled                                             |                                                                      | SREFx                                         | Bits 15-13           | Select reference.                                      |                                                                                                                  |                                             |                                                                                  |                       |                    |
| 1 1 Table                                                          | e 15-4. Common                                                                     | 1<br>Iv Used Bau                | LPM4<br>Id Rates, S |                               | clocks disabled                   |                                        |              | void serial_charTX(char c) { while(!(IFG2 & UCA0TXIFG));                                                                                                               | // Wait until                  | the transmit buffer                          | is empty                                             |                                                                      |                                               |                      | 001 V <sub>R*</sub> = V <sub>RI</sub>                  | $_{C}$ and $V_{R} = V_{SS}$<br>$_{SF+}$ and $V_{R} = V_{SS}$<br>$_{RSF+}$ and $V_{R} = V_{SS}$ . De              | wiese with V                                | onh                                                                              |                       |                    |
| BRCLK Baud Ra                                                      | Rate UCRRy                                                                         | UCBRSx                          | UCBRFx              | 1                             | TX Error [%]                      | Maximum RX I                           | Error (%)    | UCAOTXBUF = c;                                                                                                                                                         |                                | character through th                         |                                                      |                                                                      |                                               |                      | 011 V <sub>R*</sub> = Bu                               | effered $V_{RREF+}$ and $V_{R-}$ of $V_{RREF-}$ and $V_{R-}$ of $V_{RREF-}$ and $V_{R-}$                         | = V <sub>ss</sub> . Devices w               | ith V <sub>eREF+</sub> pin only.                                                 |                       |                    |
| [Hz] [Baud<br>1,000,000 9600                                       | uaj                                                                                | 1                               | 0                   | -0.5                          | 0.6                               | -0.9                                   | 1.2          | void clock_init(void) {<br>DCOCTL = 0x00;                                                                                                                              |                                |                                              |                                                      |                                                                      |                                               |                      | 101 V <sub>R*</sub> = V <sub>RI</sub>                  | $c$ and $v_R = v_{REF}/v_{eff}$<br>$c_{F+}$ and $V_R = V_{REF}/V_{eff}$<br>$c_{C_R}$ and $V_R = V_{REF}/V_{eff}$ | PEF. Devices with                           | V <sub>eREFai</sub> pins only.                                                   |                       |                    |
| 1,000,000 19200                                                    | 200 52                                                                             | 0                               | 0                   | -1.8                          | 0                                 | -2.6                                   | 0.9          | BCSCTL1 = CALBC1_1MHZ;<br>DCOCTL = CALDCO_1MHZ;                                                                                                                        | // Calibrate t                 | to 1 MHz                                     |                                                      |                                                                      | ADC10SHTx                                     | Rits 12-11           | 111 V <sub>R*</sub> = Bu<br>ADC10 sample-a             | ffered V <sub>epcc</sub> , and V <sub>p.</sub>                                                                   | = V <sub>REF</sub> / V <sub>aREF</sub> . De | evices with V <sub>encon</sub> , p                                               | ins only.             |                    |
| 1,000,000 56000                                                    | 17                                                                                 | 7                               | 0                   | -1.8<br>-4.8                  | 0.8                               | -3.6<br>-8.0                           | 1.8          | mainTX.c                                                                                                                                                               |                                |                                              |                                                      |                                                                      |                                               |                      | 00 4 × ADC<br>01 8 × ADC                               | 10CLKs                                                                                                           |                                             |                                                                                  |                       |                    |
| 1,000,000 11520<br>1,000,000 12800                                 |                                                                                    | 6<br>7                          | 0                   | -7.8<br>-10.4                 | 6.4                               | -9.7<br>-18.0                          | 16.1<br>11.6 | #include <msp430g2553.h><br/>#include "serial_msp.h"</msp430g2553.h>                                                                                                   |                                |                                              |                                                      |                                                                      |                                               |                      | 10 16 × AD0                                            | C10CLKs                                                                                                          |                                             |                                                                                  |                       |                    |
| 1,000,000 256000<br>Table 1                                        | 000 3<br>e 15-5. Common                                                            | 7<br>Ny Used Bar                | 0<br>Id Rates S     | -29.6<br>Settings and         | 0<br>nd Errors 110                | -43.6<br>COS16 = 1                     | 5.2          | void main(void) {<br>WDTCTL = WDTHOLD + WDTPW                                                                                                                          | ; // Stop Watc                 | hdog timer                                   |                                                      |                                                                      | ADC10SR                                       | Bit 10               | Setting ADC10SF                                        | rate. This bit selects<br>R reduces the current                                                                  | t consumption of                            | ffer drive capability<br>the reference buffer                                    | for the maximum s     | ampling rate.      |
| BRCLK Baud Ra                                                      | Rate ucop                                                                          | UCBRSx                          | UCBRFx              | 1                             | TX Error [%]                      | Maximum RX I                           | Error (9/1   | P1DIR = BIT0 + BIT6;<br>P1OUT &= ~(BIT0 + BIT6);                                                                                                                       | // Turn off L                  |                                              | its                                                  |                                                                      |                                               |                      | 1 Referenc                                             | ce buffer supports up<br>ce buffer supports up                                                                   |                                             |                                                                                  |                       |                    |
| [Hz] [Baud]                                                        | uaj                                                                                | 0                               | 8                   | -1.8                          | 0                                 | -2.2                                   | 0.4          | P2DIR &= ~(BIT0 + BIT1 + BIT2);<br>clock_init();                                                                                                                       | // Set clock f                 | ton pins as inputs<br>frequency to 1 MH      | z                                                    |                                                                      | REFOUT                                        | Bit 9                |                                                        | ce output off                                                                                                    |                                             | ata auto                                                                         |                       |                    |
| 1,000,000 19200                                                    | 100 3                                                                              | 0                               | 4                   | -1.8<br>-34.4                 | 0                                 | -2.6                                   | 0.9          | serial_init();<br>while(1) {                                                                                                                                           | // Initialize (                | UART module                                  |                                                      |                                                                      | REFBURST                                      | Bit 8                | Reference burst.                                       | ce output on. Devices                                                                                            |                                             | F. pin only.                                                                     |                       |                    |
| 1,000,000 57600<br>15.4.1 UCAxCTL0                                 |                                                                                    | ontrol Regis                    | ter 0               | -34.4                         | 0                                 | -33.4                                  | 0            | if( (P2IN & BIT2) == BIT2) {                                                                                                                                           | // Turn on B                   | OTH LED                                      |                                                      |                                                                      | MSC                                           | Bit 7                | 1 Referenc                                             | ce buffer on continuou<br>ce buffer on only durir<br>and conversion. Valid                                       | ng sample-and-o                             |                                                                                  |                       |                    |
|                                                                    | CPAR UCMS                                                                          | B UC7B                          |                     | CSPB                          | UCMODE                            | Ex L                                   | JCSYNC       | delay_cycles(1000000);                                                                                                                                                 | " Tulli oli b                  | OTTLEDS                                      |                                                      |                                                                      | moc                                           | Dit 7                | 0 The sam                                              | pling requires a rising<br>rising edge of the SH                                                                 | g edge of the SH                            | I signal to trigger ea                                                           | ch sample-and-cor     | nversion.          |
| UCPEN Bit 7                                                        | Parity enable                                                                      |                                 |                     | rw-0                          | rw-0                              | rw-0                                   | rw-0         | if( (P2IN & BIT1) == BIT1) {<br>serial_charTX('i');                                                                                                                    |                                |                                              |                                                      |                                                                      | REF2_5V                                       | Bit 6                | sample-s                                               | and-conversions are p<br>ator voltage. REFON                                                                     | performed autom                             | atically as soon as t                                                            | he prior conversion   | n is completed     |
|                                                                    |                                                                                    | led. Parity bit i               |                     |                               |                                   | ed (UCAxRXD). In                       |              | PIOUT = BIT6;<br>PIOUT &= ~BIT0;                                                                                                                                       | // Turn On g<br>// Turn Off r  | reen LED<br>red LED                          |                                                      |                                                                      |                                               |                      | 0 1.5 V<br>1 2.5 V                                     | -                                                                                                                |                                             |                                                                                  |                       |                    |
| UCPAR Bit 6                                                        | address-bit m<br>Parity select.                                                    |                                 |                     |                               |                                   | the parity calcul                      | lation.      | delay_cycles(1000000);                                                                                                                                                 | // Tuni On i                   | CG ELLO                                      |                                                      |                                                                      | REFON                                         | Bit 5                | Reference general                                      |                                                                                                                  |                                             |                                                                                  |                       |                    |
| UCMSB Bit 5                                                        | 0 Odd parity                                                                       |                                 |                     | 1 Even parit                  | ity                               | smit shift registe                     | er.          | if( (P2IN & BIT0) == BIT0) {     serial_charTX('d');                                                                                                                   |                                |                                              |                                                      |                                                                      | ADC100N                                       | Bit 4                | 1 Reference<br>ADC10 on                                |                                                                                                                  |                                             |                                                                                  |                       |                    |
| UC7BIT Bit 4                                                       | 0 LSB first<br>Character len                                                       |                                 |                     | 1 MSB first                   | t                                 |                                        | _            | P1OUT I= BIT0;<br>P1OUT &= ~BIT6;                                                                                                                                      | // Turn On re<br>// Turn Off g | ed LED<br>green LED                          |                                                      |                                                                      |                                               |                      | 0 ADC10 c                                              | on                                                                                                               |                                             |                                                                                  |                       |                    |
| UCSPB Bit 3                                                        | 0 8-bit data                                                                       |                                 |                     | 1 7-bit data                  |                                   |                                        |              | delay_cycles(1000000);<br>} else {                                                                                                                                     |                                |                                              |                                                      |                                                                      | ADC10IE                                       | Bit 3                | ADC10 interrupt of Interrupt                           | disabled                                                                                                         |                                             |                                                                                  |                       |                    |
|                                                                    | O One stop bit                                                                     |                                 |                     | 1 Two stop                    |                                   |                                        | -0           | P1OUT &= ~(BIT0 + BIT6);                                                                                                                                               | // Turn on Ll                  | EDs                                          |                                                      |                                                                      | ADC10IFG                                      | Bit 2                | 1 Interrupt<br>ADC10 interrupt to<br>when the interrup | enabled<br>flag. This bit is set if A<br>at request is accepted                                                  | ADC10MEM is to                              | aded with a convers                                                              | ion result. It is aut | omatically rese    |
| JCMODEx Bits 2-1                                                   | 00 UART mode                                                                       | e                               |                     | ше asynchro                   | mous mode i                       | wnen UCSYNC :                          | <u> </u>     | }                                                                                                                                                                      |                                |                                              |                                                      |                                                                      |                                               |                      | when a block of to                                     | nt request is accepted<br>transfers is completed<br>rupt pending                                                 |                                             | on by software. Whi                                                              | using the DTC t       | s rag is set       |
|                                                                    | 01 Idle-line mi<br>10 Address-bit                                                  | t multiprocess                  | or mode             |                               |                                   |                                        |              | Serial_MSP_Interrupt.c void serial_init_inter(void) {                                                                                                                  |                                |                                              |                                                      |                                                                      | ENC                                           | Bit 1                | 1 Interrupt<br>Enable conversio                        | pending                                                                                                          |                                             |                                                                                  |                       |                    |
| JCSYNC Bit 0                                                       | 11 UART mode<br>Synchronous                                                        | e with automo                   |                     | ite detection                 |                                   |                                        |              | void serial_init_inter(void) {<br>P1SEL = 0x02;<br>P1SEL 2 = 0x02                                                                                                      |                                |                                              |                                                      |                                                                      | *                                             |                      | 0 ADC10 d                                              | disabled<br>enabled                                                                                              |                                             |                                                                                  |                       |                    |
| 5.4.2 UCAxCTL1                                                     | 0 Asynchronou                                                                      | us mode                         | ter 1               | 1 Synchrono                   | ous mode                          |                                        |              | UCA0CTL1 = UCSWRST;<br>UCA0CTL0 = 0x00;                                                                                                                                | // Disable U.                  | ART module for co<br>LSB first, 8-bit dat    | onfiguration<br>ta. 1 stop bit IIAD                  | T. Asynchronous                                                      | ADC10SC                                       | Bit 0                | Start conversion. with one instruction                 | Software-controlled s<br>on. ADC10SC is rese                                                                     | sample-and-conv<br>et automatically.        | ersion start. ADC10                                                              | SC and ENC may        | be set togethe     |
| 7 UCSSELX                                                          | 6 5                                                                                | 4                               |                     | 3<br>DORM III                 | 2<br>CTXADDP                      | 1<br>UCTXBRK U                         | 0<br>CSWRST  | UCA0CTL1  = 0xc0;<br>UCA0BR0 = 104;                                                                                                                                    | // SMCLK s<br>// 9600 Baud     | source, keep in rese<br>d rate - Assumes 1   | t state<br>I MHz clock                               | , , memorious                                                        |                                               |                      | 0 No samp<br>1 Start san                               | ole-and-conversion sta<br>mple-and-conversion                                                                    | art                                         |                                                                                  |                       |                    |
| rw-0 rw                                                            | rw-0 rw-0                                                                          | ) rw-C                          | ) r                 | rw-0                          | rw-0                              | rw-0                                   | rw-1         | UCA0MCTL = 0x02;<br>UCA0CTL1 &= ~UCSWRST;                                                                                                                              | // 2nd Stage<br>// Enable UA   | modulation = 1, O                            | versampling off                                      |                                                                      | 22.3.2 AD                                     | C10CTL1,             | 13                                                     | trol Register 1                                                                                                  | - 11                                        | 10                                                                               | 9                     | 8                  |
| JCSSELX BITS 7-6                                                   | 00 UCLK                                                                            | irce seiect. In                 |                     | 01 ACLK                       | .K SOURCE CIO                     | CK.                                    |              | } char serial charRX(void) {                                                                                                                                           |                                |                                              |                                                      |                                                                      | rw-(0)                                        | rw-(0)               | INCHx<br>rw-(0)                                        | rw-(0)                                                                                                           | rw-(0)                                      | rw-(0)                                                                           | ADC10DF<br>rw-(0)     | rw-(0)             |
| UCRXEIE Bit 5                                                      | 10 SMCLK<br>Receive erron                                                          |                                 | er interrupt        |                               |                                   |                                        |              | while(!(IFG2 & UCA0RXIFG));<br>return UCA0RXBUF;                                                                                                                       | // Wait until<br>// Return rec | a character has bee<br>eived character       | en received                                          |                                                                      | 7                                             | 6<br>ADC10DI         | 5                                                      | 4                                                                                                                | 3<br>0SSELx                                 | 2<br>CONS                                                                        | 1                     | 0<br>ADC10BUSY     |
|                                                                    | 0 Erroneous ci<br>1 Erroneous ci                                                   |                                 |                     |                               |                                   |                                        |              | } void clock_init(void) {                                                                                                                                              |                                |                                              |                                                      |                                                                      | rw-(0)                                        | rw-(0)               | rw-(0)                                                 | rw-(0)                                                                                                           | rw-(0)                                      | rw-(0)                                                                           | rw-(0)                | r-0                |
| JCBRKIE Bit 4                                                      | Receive break<br>O Received bre                                                    |                                 |                     |                               |                                   |                                        |              | DCOCTL = 0x00;<br>BCSCTL1 = CALBC1_1MHZ; //                                                                                                                            | Calibrate to 1                 | MHz                                          |                                                      |                                                                      | INCHx                                         |                      | fified only when EN<br>Input channel sel               | lect. These bits select                                                                                          | t the channel for                           | a single-conversion                                                              | or the highest cha    | innel for a        |
| JCDORM Bit 3                                                       | 1 Received bre<br>Dormant, Put                                                     | eak characters                  | s set UCAxR         |                               |                                   |                                        |              | DCOCTL = CALDCO_1MHZ;<br>BCSCTL1  = XT2OFF + DIVA_0;                                                                                                                   | VOLD 4                         |                                              |                                                      |                                                                      |                                               |                      | 0000 A0                                                | versions. Only availab                                                                                           | ble ADC channel                             | s should be selected                                                             | See device spec       | ific datasheet.    |
| CDONN BICS                                                         | 0 Not dorman                                                                       | t. All received                 | characters          |                               |                                   |                                        |              | BCSCTL3 = XT2S_0 + LFXT1S_2 +<br>}                                                                                                                                     | F XCAP_1;                      |                                              |                                                      |                                                                      |                                               |                      | 0001 A1<br>0010 A2                                     |                                                                                                                  |                                             |                                                                                  |                       |                    |
|                                                                    | set UCAxRXIFO                                                                      | G. In UART mo                   | de with aut         | tomatic baud                  |                                   | with address bi<br>ion only the con    |              | mainRX.c<br>#include <msp430g2553.h></msp430g2553.h>                                                                                                                   |                                |                                              |                                                      |                                                                      |                                               |                      | 0011 A3<br>0100 A4                                     |                                                                                                                  |                                             |                                                                                  |                       |                    |
| UCTXADDR Bit 2                                                     | of a break and<br>Transmit add                                                     |                                 |                     |                               | vill be marked                    | d as address de                        | pendina      | #include "Serial_MSP_Interrupt.h"  void main(void) {                                                                                                                   |                                |                                              |                                                      |                                                                      |                                               |                      | 0101 A5<br>0110 A6                                     |                                                                                                                  |                                             |                                                                                  |                       |                    |
|                                                                    | on the selecte  O Next frame I                                                     | ed multiproces                  | ssor mode.          |                               |                                   |                                        |              | WDTCTL = WDTHOLD + WDTPW<br>P1DIR  = BIT0 + BIT6:                                                                                                                      | ; // Stop Wate                 | chdog timer<br>: LED pins as outpu           | ıts                                                  |                                                                      |                                               |                      | 0111 A7<br>1000 V <sub>eREF+</sub>                     |                                                                                                                  |                                             |                                                                                  |                       |                    |
| UCTXBRK Bit 1                                                      | 1 Next frame I                                                                     | transmitted is                  | an address          |                               |                                   | ransmit buffer.                        | In LIADT     | P1OUT &= ~(BIT0 + BIT6);<br>clock_init();                                                                                                                              | // Turn off L                  | EDs<br>frequency to 1 MH                     |                                                      |                                                                      |                                               |                      |                                                        | ature sensor                                                                                                     |                                             |                                                                                  |                       |                    |
| OCIABRE BET                                                        | mode with au                                                                       | tomatic baud                    | l rate detec        | ction 055h mu                 | ust be writte                     | en into UCAxTXI                        | BUF          | serial_init_inter();<br>IFG2 &= ~(UCA0RXIFG);                                                                                                                          | // Initialize U                | UART module                                  | -                                                    |                                                                      |                                               |                      |                                                        | s) / 2, A12 on MSP43                                                                                             | 30F22xx devices                             |                                                                                  |                       |                    |
|                                                                    | transmit buffe                                                                     | er.                             |                     |                               | wise on mus                       | st be written int                      | to tne       | <pre>IE2  = UCA0RXIE;<br/>bis_SR_register(GIE);</pre>                                                                                                                  | // Enable UA                   | ART interrupt                                |                                                      |                                                                      |                                               |                      | 1110 (V <sub>oc</sub> - V <sub>s</sub>                 | <sub>ss</sub> ) / 2, A13 on MSP43<br><sub>ss</sub> ) / 2, A14 on MSP43                                           | 30F22xx devices                             |                                                                                  |                       |                    |
|                                                                    | 0 Next frame t<br>1 Next frame t                                                   | transmitted is                  |                     |                               | ch                                |                                        |              | while(1) { } }                                                                                                                                                         |                                |                                              |                                                      |                                                                      | SHSx                                          | Bits 11-10           | Sample-and-hold                                        | ss) / 2, A15 on MSP43<br>I source select.                                                                        | 3UF22xx devices                             |                                                                                  |                       |                    |
| UCSWRST Bit 0                                                      | Software rese<br>0 Disabled. US                                                    |                                 | sed for ope         | ration.                       |                                   |                                        |              | #pragma vector = USCIABORX_VECTO<br>interrupt void RX_Function(void) {                                                                                                 | R //interrupt ve               | ector routine                                |                                                      |                                                                      |                                               |                      | 00 ADC10S<br>01 Timer_A                                | .OUT1 <sup>(1)</sup>                                                                                             |                                             |                                                                                  |                       |                    |
| 15.4.3 UCAxBR0,                                                    | 1 Enabled. US<br>RO. USCI Ax Bai                                                   |                                 |                     |                               |                                   |                                        |              | char c;<br>while(!(IFG2 & UCA0RXIFG));//                                                                                                                               | This should me                 | ake the CPLI wait s                          | ince the flag should                                 | d he set already                                                     | ADC10DF                                       | Bit 9                | 10 Timer_A<br>11 Timer_A<br>ADC10 data form            | .OUT2 (Timer_A.OUT                                                                                               | T1 on MSP430F2                              | 20x0, MSP430G2x3                                                                 | 1, and MSP430G2       | tx30 devices)(1)   |
| 15.4.4 UCAxBR1,                                                    |                                                                                    | ud Rate Con                     | trol Regis          |                               |                                   |                                        | 0            | c = UCA0RXBUF;<br>switch(c) {                                                                                                                                          |                                | ived character                               | mee the mig should                                   | a be set aneady                                                      | ADCTODE                                       | DII 9                | 0 Straight I                                           | binary                                                                                                           |                                             |                                                                                  |                       |                    |
| , .                                                                |                                                                                    |                                 | UCBRx               | -                             |                                   |                                        | -            | case 'r':<br>PIOUT = (BIT0 + BIT6);                                                                                                                                    | // Reset the o                 |                                              |                                                      |                                                                      | ISSH                                          | Bit 8                | Invert signal sam                                      |                                                                                                                  | t inverted                                  |                                                                                  |                       |                    |
| UCBRx 7-0                                                          | Clock prescale<br>UCAxBR1 × 25                                                     |                                 |                     |                               | The 16-bit va                     | alue of (UCAxBRI                       | 0+           | break;<br>case 'i':                                                                                                                                                    |                                |                                              |                                                      |                                                                      | ADC10DIVx                                     | Bits 7-5             |                                                        | nple-input signal is inv                                                                                         |                                             |                                                                                  |                       |                    |
| 15.4.5 UCAxMCT                                                     |                                                                                    |                                 |                     |                               |                                   |                                        |              | P1OUT = BIT6;<br>P1OUT &= ~BIT0;                                                                                                                                       | // Turn On g<br>// Turn Off r  |                                              |                                                      |                                                                      |                                               |                      | 000 /1<br>001 /2                                       |                                                                                                                  |                                             |                                                                                  |                       |                    |
| 7 6                                                                | 6 5<br>UCBRFx                                                                      | 4                               |                     | 3                             | 2<br>UCBRSx                       | 1                                      | 0<br>UCOS16  | break;<br>case 'd':                                                                                                                                                    |                                |                                              |                                                      |                                                                      |                                               |                      | 010 /3<br>011 /4                                       |                                                                                                                  |                                             |                                                                                  |                       |                    |
|                                                                    | rw-0 rw-0<br>4 First modulati                                                      |                                 |                     | rw-0                          | rw-0                              | rw-0                                   | rw-0         | PIOUT = BITO;<br>PIOUT &= ~BIT6;                                                                                                                                       | // Turn On ro<br>// Turn Off g |                                              | T<br>≸ Pulluı                                        | p T<br>Pulldowi                                                      | 1                                             |                      | 100 /5<br>101 /6                                       |                                                                                                                  |                                             |                                                                                  |                       |                    |
|                                                                    | when UCOS16                                                                        | 5 = 1. Ignored                  | with UCOS1          | 16 = 0. Table 1               | 15-3 shows ti                     | the modulation                         | pattern.     | default:                                                                                                                                                               | //T                            | ED.                                          | <b>-</b> -⊳                                          | - ├─⊳                                                                |                                               |                      | 110 /7<br>111 /8                                       |                                                                                                                  |                                             |                                                                                  |                       |                    |
|                                                                    | 1 <u>Second modul</u><br>BITCLK. Table                                             | 15-2 shows th                   | e modulatio         | z oits determi<br>on pattern. | ine the modu                      | Jiation pattern j                      | jor          | P1OUT &= ~(BIT0 + BIT6);<br>break;                                                                                                                                     | , // rum off L                 | EL/S                                         | V <sub>0</sub> =1                                    | ¥ V <sub>0</sub> =0                                                  | ADC10SSELx                                    | Bits 4-3             | ADC10 clock sou<br>00 ADC100                           |                                                                                                                  |                                             |                                                                                  |                       |                    |
| JCOS16 Bit 0                                                       | Oversampling<br>0 Disabled                                                         |                                 |                     | 1 Enabled                     |                                   |                                        |              | }                                                                                                                                                                      |                                |                                              | Ţ                                                    | Ţ                                                                    |                                               |                      | 01 ACLK<br>10 MCLK                                     |                                                                                                                  |                                             |                                                                                  |                       |                    |
| 15.4.7 UCAxRXB                                                     | BUF, USCI_Ax                                                                       | 4                               |                     | 3                             | 2                                 | 1                                      | 0            | ADC_MSP.c<br>void adc_init() { // Initialize ADC                                                                                                                       |                                |                                              |                                                      |                                                                      | CONSEQx                                       | Bits 2-1             | 11 SMCLK<br>Conversion seque                           |                                                                                                                  |                                             |                                                                                  |                       |                    |
|                                                                    | rw rw                                                                              | rw                              |                     | rw                            | rw                                | nw                                     | rw           | P1DIR &= 0x0001;<br>ADC10CTL0 = ADC10ON + ADC10                                                                                                                        | // Set Pins as i               | nputs                                        | ADC modula                                           |                                                                      |                                               |                      | 01 Sequenc                                             | hannel-single-convers<br>ce-of-channels                                                                          | sion                                        |                                                                                  |                       |                    |
| JCRXBUFx Bits 7-0                                                  | the receive sh                                                                     | nift register. Re               | eading UCA          | AxRXBUF reset                 | ets the receive                   | e-error bits, the                      | UCADDR       | ADC10CTL1 = CONSEQ_0 + ADC                                                                                                                                             | $10SSEL_0 + A$                 | DC10DIV_0 + SH<br>log function in pins       | S_0 + INCH_0;                                        |                                                                      | ADC-105                                       | Do ^                 | 11 Repeat-s                                            | single-channel<br>sequence-of-channels                                                                           |                                             | maniar ::                                                                        |                       |                    |
|                                                                    | MSB is always                                                                      | s reset.                        |                     |                               | UCAxRXBUF i                       | is LSB justified o                     | and the      | }                                                                                                                                                                      |                                |                                              | nnale                                                |                                                                      | ADC10BUSY                                     | Bit 0                | 0 No opera                                             | is bit indicates an activation is active.  noe sample or conve                                                   |                                             | iversion operation                                                               |                       |                    |
| 5.4.8 UCAXTXB                                                      |                                                                                    |                                 | ffer Regis          | ster<br>3                     | 2                                 | 1                                      | 0            | int adc_measureAll(void) {     return (adc_measure(X_AXIS) + adc_                                                                                                      |                                | sum of all ADC cha<br>AXIS) + adc_meast      |                                                      |                                                                      |                                               |                      |                                                        | an one timer module                                                                                              | exists on the dev                           |                                                                                  | ack from              | inta-1             |
| nv n                                                               | rw rw                                                                              | rw                              | UCTXBUFx            | rw                            | rw                                | rw                                     | rw           |                                                                                                                                                                        |                                | ected ADC Channe                             | el: X_AXIS, Y_AX                                     | IS, Z_AXIS                                                           | l                                             | asm:                 |                                                        |                                                                                                                  | (                                           | er; index for st<br>CMP #0x05,                                                   | J(R7)                 | nter)              |
| JCTXBUFx Bits 7-0                                                  |                                                                                    |                                 |                     |                               |                                   |                                        |              | ADC10CTL0 &= ~ENC;<br>// Configure the MUX channel to                                                                                                                  |                                |                                              |                                                      |                                                                      | if (b>=5&&<br>do_thi                          |                      |                                                        |                                                                                                                  | (                                           | L do_that<br>CMP #0x02,                                                          | K(R7)                 |                    |
|                                                                    | buffer clears L                                                                    | JCAxTXIFG. Th                   | e MSB of U          | ICAXTXBUF is                  | not used for                      | ng to the transm<br>r 7-bit data and   | is reset.    | ADC10CTL1 = CONSEQ_0 + ADC1<br>ADC10CTL0  = ENC + ADC10SC;                                                                                                             | 10SSEL_0 + A                   | DC10DIV_0 + SH                               | S_0 + (channel <<                                    | : 12);                                                               | } else { do_that                              |                      |                                                        |                                                                                                                  | J                                           | NE do_that<br>MP do_this                                                         |                       |                    |
| 7 IE2, Inter                                                       | errupt Enable R                                                                    | egister 2                       |                     | 3                             | 2                                 | 1                                      | 0            | while ( (ADC10CTL0 & ADC10IFG                                                                                                                                          | ) == 0);                       | // Wait until                                | the conversion is                                    | finished                                                             | }                                             | ,                    |                                                        |                                                                                                                  | do_that                                     |                                                                                  |                       |                    |
|                                                                    | 2 75 11                                                                            |                                 |                     | 1                             |                                   | rw-0                                   | rw-0         |                                                                                                                                                                        |                                | C before retrieving<br>surement value        | me conversion fro                                    | ли шетогу                                                            |                                               |                      |                                                        |                                                                                                                  | do_this                                     | MP done                                                                          |                       |                    |
|                                                                    | <ol> <li>These bits may</li> <li>USCI_A0 trans</li> </ol>                          | smit interrupt                  | enable              |                               |                                   | r data sheet).                         |              | mainADC.c                                                                                                                                                              |                                |                                              |                                                      |                                                                      |                                               |                      |                                                        |                                                                                                                  |                                             | IMD 1                                                                            |                       |                    |
| JCAORXIE Bit 0                                                     | 0 Interrupt dis                                                                    |                                 |                     | 1 Interrupt                   |                                   |                                        |              | #include <msp430g2553.h><br/>#include "adc_msp.h"</msp430g2553.h>                                                                                                      |                                |                                              |                                                      |                                                                      |                                               |                      |                                                        |                                                                                                                  | done                                        | MP done                                                                          |                       |                    |
| 15.4.13 IFG2, Inte                                                 | 0 Interrupt dis                                                                    | sabled                          | _                   | 1 Interrupt                   | enabled                           |                                        |              | #include "lcd_lib.h"                                                                                                                                                   |                                |                                              |                                                      |                                                                      | switch (myl-<br>case a                        |                      |                                                        |                                                                                                                  |                                             | CMP #a, &m<br>NE sw_01                                                           | yByte                 |                    |
| 7 6                                                                | 6 5                                                                                | 4                               |                     | 3                             | 2                                 | 1<br>UCA0TXIFG UC                      | O            | void main(void) {  WDTCTL = WDTPW + WDTHOLD                                                                                                                            |                                | ıdog                                         |                                                      |                                                                      | l                                             | do_A;<br>break;      |                                                        |                                                                                                                  | (                                           | CALL #do_A<br>IMP sw_end                                                         | ı                     |                    |
| Bits 7-2                                                           | 2 These bits ma                                                                    | y be used by                    | ther modul          | les (see the d                | device-specific                   | rw-1<br>ic data sheet).                | rw-0         | lcd_init(); //initialize LCD                                                                                                                                           | er .                           |                                              |                                                      |                                                                      | case b                                        | :                    |                                                        |                                                                                                                  | sw_01:                                      | CMP #b, &n                                                                       |                       |                    |
|                                                                    |                                                                                    | smit interrupt                  | flag. UCA01         | TXIFG is set w                | when UCAOTX                       | KBUF is empty.                         |              | P1DIR = BIT6;<br>send_cmd(0x0C); //disable the blinki                                                                                                                  | ng cursor                      | C → asm                                      |                                                      |                                                                      | l                                             | do_B;<br>break;      |                                                        |                                                                                                                  | J                                           | NE sw_def                                                                        | ,_,_                  |                    |
| JCAOTXIE Bit 1                                                     | USCI_A0 trans                                                                      |                                 |                     |                               |                                   | BUF has receive                        | d a          | while(1) { int x;                                                                                                                                                      |                                | while(:1-2)                                  | go_back CMI<br>JEQ                                   |                                                                      |                                               | do_D;                |                                                        |                                                                                                                  | J                                           | CALL #do_B<br>IMP sw_end                                                         | ı                     |                    |
|                                                                    | USCI_A0 trans  O No interrupt  USCI_A0 recei                                       |                                 |                     |                               |                                   |                                        |              |                                                                                                                                                                        | annel 0 (P1.0)                 | while(i!=3)                                  | CAL                                                  | .L #do_it                                                            |                                               | break;               |                                                        |                                                                                                                  |                                             | CALL #do_D                                                                       |                       |                    |
|                                                                    | USCI_A0 trans<br>0 No interrupt                                                    | racter.                         |                     | 1 Interrupt                   | pending                           |                                        |              | x=adc_measure(0); //use 0 for ch                                                                                                                                       |                                | T .                                          |                                                      |                                                                      | 3                                             |                      |                                                        |                                                                                                                  |                                             |                                                                                  |                       |                    |
| ICAORXIE Bit 0                                                     | USCI_A0 trans O No interrupt USCI_A0 recei complete char O No interrupt            | racter.<br>t pending            |                     |                               |                                   | iuested?                               |              | if(x>=512){<br>P1OUT  = BIT6;                                                                                                                                          |                                | do_it;                                       | JMP<br>done                                          | go_back                                                              | }                                             |                      |                                                        |                                                                                                                  | sw_end:                                     | MP sw_enc                                                                        | 1                     |                    |
| G.7 What                                                           | USCI_A0 trans O No interrupt USCI_A0 recei complete char O No interrupt            | racter.<br>t pending            |                     |                               |                                   | juested?                               |              | if(x>=512){                                                                                                                                                            |                                | do_it;<br>}                                  |                                                      | go_back                                                              | inti;                                         | n.: .                |                                                        |                                                                                                                  | sw_end:                                     | bss i, 2 ; 2 b                                                                   | ytes global var       | riable i           |
| 6.7 What  SP-2; PC→SP. SP-2; SR→SP                                 | USCI_A0 trans 0 No interrupt USCI_A0 recei complete char 0 No interrupt at Happer  | racter.<br>t pending            | an In               | terrupt                       | t Is Req                          |                                        |              | if(x>=512){<br>PIOUT  = BIT6;<br>} else {<br>PIOUT &= ~BIT6;<br>}                                                                                                      |                                | }                                            | done do_it: CLR                                      | R J(R7)                                                              | for(i=10; i>4                                 |                      |                                                        |                                                                                                                  | sw_end:                                     | bss i, 2; 2 b<br>nov.w #10,&i<br>call #do_do                                     | ytes global var       | riable i           |
| 6.7 What<br>SP-2; PC→SP.<br>SP-2; SR→SP                            | USCI_A0 trans O No interrupt USCI_A0 recei complete char O No interrupt            | racter.<br>t pending            | an In               |                               | t Is Req                          |                                        |              | if(x>=512){<br>P1OUT l= BIT6;<br>} else {<br>P1OUT &= ~BIT6;<br>}<br>delay_ms(250);<br>gotoXy(0.0);                                                                    |                                | for(i=0; i<64;i++)                           | done do_it:  CLR go_back MO' CMI                     | R J(R7)<br>V J(R7), R5<br>P #0x64, R5                                |                                               | t();                 |                                                        |                                                                                                                  | sw_end:                                     | bss i, 2;2 b<br>nov.w #10,&i                                                     | oytes global var      | riable i           |
| UCAOTXIE Bit 1  UCAOTXIE Bit 0  6.7 What  SP-2; PC→SP.  (a) Before | USCI_A0 trans 0 No interrupt USCI_A0 recei complete char 0 No interrupt at Happer  | racter.<br>t pending<br>ns when | an In               | (b) After ente                | t Is Req                          | upt                                    |              | if(x>=512){     PIOUT  = BIT6; } else {     PIOUT &= -BIT6; } delay_ms(250); gotoXy(0,0); write_int(x); write_string("Value");                                         |                                | }                                            | done do_it:  CLR go_back MO' CMI JGE CAL             | R J(R7)<br>V J(R7), R5<br>P #0x64, R5<br>done<br>LL #do_rep          | for(i=10; i><br>{<br>do_do<br>delay(<br>do_da | t();<br>);<br>sh();  |                                                        |                                                                                                                  | sw_end:  r fl_ck: c                         | bss i, 2; 2 b<br>nov.w #10,&i<br>call #do_dc<br>call #delay                      | oytes global var      | riable i           |
| 6.7 What<br>SP-2; PC→SP.<br>SP-2; SR→SP                            | USCI_A0 trans 0 No interrupt USCI_A0 recei complete char 0 No interrupt at Happer  | racter.<br>t pending<br>ns when | an In               | (b) After ente                | t Is Req                          |                                        |              | if(x>=512), PIOUT I= BIT6; ) else { PIOUT &= -BIT6; } delay_ms(250); gotoXy(0.0); write_int(x); write_inting("Value"); gotoXy(0, 1); // Move cursor to 2 write_int(x); |                                | for(i=0; i<64;i++)                           | done do_it:  CLR go_back MO' CMI JGE CAI INC JMP     | R J(R7)<br>V J(R7), R5<br>P #0x64, R5<br>done<br>LL #do_rep<br>J(R7) | for(i=10; i>4<br>{<br>do_do<br>delay(         | t();<br>);<br>sh();  |                                                        |                                                                                                                  | sw_end:  I  ff_ck:  c  c  c  d  j           | bss i, 2; 2 b<br>nov.w #10,&i<br>call #do_do<br>call #delay<br>call #do_da       | oytes global var      | riable i           |
| 6.7 What  SP-2, PC-SE, SP-2; SR-SSP (a) Before                     | USCI_A0 trans 0 No interrupt USCI_A0 recei complete char 0 No interrupt  at Happer | ns when                         | an In               | (b) After ente                | t Is Req                          | ← SP                                   | return       | if(x>=51.2){ PIOUT I= BIT6; } clse { PIOUT &= ABIT6; } delay_ms(2.50); gotoXy(0.0); write_int(x); write_string(" Value"); gotoXy(0, 1); // Move cursor to 2            |                                | for(i=0; i<64;i++)                           | done do_it: CLR go_back MO' CMI JGE CAL INC JMP done | R J(R7)<br>V J(R7), R5<br>P #0x64, R5<br>done<br>LL #do_rep          | for(i=10; i><br>{<br>do_do<br>delay(<br>do_da | t();<br>);<br>sh();  |                                                        |                                                                                                                  | sw_end:  fl_ck:  c  c  c  c                 | bss i, 2;2 b<br>nov.w #10,&i<br>all #do_do<br>all #delay<br>all #delay<br>dec &i | oytes global var      | riable i           |
| 6.7 What P-2; PC→SP. P-2; SR→SP (a) Before                         | USCI_A0 trans 0 No interrupt USCI_A0 recei complete char 0 No interrupt  at Happer | ns when                         | an In               | (b) After ente                | t Is Req                          | ← SP                                   | return       | if(x>=512), PIOUT I= BIT6; ) else { PIOUT &= -BIT6; } delay_ms(250); gotoXy(0.0); write_int(x); write_inting("Value"); gotoXy(0, 1); // Move cursor to 2 write_int(x); |                                | for(i=0; i<64;i++)                           | done do_it:  CLR go_back MO' CMI JGE CAI INC JMP     | R J(R7)<br>V J(R7), R5<br>P #0x64, R5<br>done<br>LL #do_rep          | for(i=10; i><br>{<br>do_do<br>delay(<br>do_da | t();<br>);<br>sh();  |                                                        |                                                                                                                  | sw_end:  I  ff_ck:  c  c  c  d  j           | bss i, 2;2 b<br>nov.w #10,&i<br>all #do_do<br>all #delay<br>all #delay<br>dec &i | oytes global var      | riable i           |